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(54) Title: DEVICE USER INTERFACE WITH TOPOLOGY MAP 
(57) Abstract 

A topology map fox a system is generated and displayed on a display 
device to indicate the various components which make up the system. The 
various components are indicated using icons each of which represent a 
respective one of the components. /When a device is acided to the systen^ 
^a^g^hi^ '^tis^ representing dmt device is automatically displayed ih^a 
l^hiSTiin^ iruferface. Similarly, when a device is removed from tiie serial 
^ gr:^phical image representing tiiat device is grayed out. leaving^a 
shadow of die graphical image until the device is eith^ jie-coupled or tl£ 
^system is powered off/ In a preferred embodiment, a user specifies a source 
device and a receive device by manipulating Che corresponding icons so as 
to cause a data transfer between the source device and tlte receive device. 
In anotiier embodiment, one or more task windows are included in the 
interface which help the user sleet the cask to be peifonned. Once selected, 
controls, commands and data related to the task are displayed within a control 
display window of die graphical user intcr&ce. Data transfer operations may 
include the transfer of video data, aiidio data, or both, bi a furtiier prefer^ 
embodiment,' tiie digital network corresponds to the IEEE 1394 Serial Bus^ 
Standard. 
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DEVICE USER INTERFACE WITH TOPOLOGY MAP 

FIELD OF THE INVENTION 

The present invention is related to the field of user interfaces and, more 
5 particularly, lo device control using a topology map displayed as part of such an 
interface. 

BACKGROUND 

The components of a computer system arc typically coupled lo a common 
bus for communicating information to one another. Various bus architectures are 

10 known in the prior an. and each bus architecture operates according to a 

communications protocol that defines the manner in which data transfer between 
components is accomplished. 

The Institute of Electrical and Electronic Engineers (IEEE) has promulgated 
a number of different bus architecture standards including IEEE standards 

1 5 document 1 394, entitled Standard for a High Performance Serial Bus (hereinafter 
"IEEE 1394 Serial Bus Standard"). A typical serial bus having the IEEE 1394 
standard architecture is comprised of a muhiplicity of nodes that are interconnected 
via point-to-point links, such as cables, that each connect a single node of the 
serial bus to another node of the serial bus. Data packets are propagated 

20 throughout the serial bus using a number of poini-to-point transactions, wherein a 
node that receives a packet from another node via a first point-to-point link 
retransmits the received packet via other point-to-point links. A tree network 
configuration and associated packet handling protocol ensures that each node 
receives every packet once. The serial bus of the IEEE 1394 Serial Bus Standard 

25 may be used as an alternate bus for the parallel backplane of a computer system, as 
a low cost peripheral bus, or as a bus bridge between architecturally compatible 
buses. 

A communicatioris protocol of the IEEE 1394 Serial Bus Standa^ 
specifies two primary types of bus access: asynchronous access and isochronoifs 
30 access. Asynchronoijs access rnay.be either "fair^o Cycle 

master access is used by nodes that need the next available opportunity to transfer 
data. Isochronous access i.s used by nodes that reguire guaranteed bandwidth, for 
example, nodes muismining video data. The transactions for each type of bus 
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access are comprised of ai least one "subaction". wherein a subacdon is a complete 
one-way transfer operation. 

The IEEE 1394 serial bus provides plug and play capabilities for 
applications. Devices can be added and removed from an IEEE 1394 bus while 
5 the bus is active. /If a deSlce is so added or removed 

automatically reconfigure itself-for transmitting data between the exisii 
However, for a user of an application at a node coupled to the bus, there is no 
specified method or apparatus for displaying the devices coupled to the IEEE 1394 
serial bus. There is also no prescribed method for monitoring the activity of the 
10 devices coupled to the IEEE 1394 serial bus. In existing analog or digiidl 

networks,-a user is not provided with a presentation of information regardi the 
network, including the ty 

which the devices.are interconnected and_the signal.flow which occurs between the 
various devices. To control any of these devices, the user must physically operate 

15 each_d,eyice separately through a control panel on the face otthat devicd^ Where 
the network in question is an analog audio/video system, a signal selector and 
complicated "spaghetti connections" are unavoidable when a user wishes to dub 
signals freely between the devices in the network. 

In the alternative, it is well known that infrared control devices exist for 

20 variety of home entertainment type products such as television. VCR, and sound 
systems. There are even a number of so-called "universal remote" products 
available that can control a number of different brands or types of equipment. 
/However, the inventors are not aware of any control device that can conirpl any ^ 
, IEEE 1 394 devittf-^Furtherrthere is no device that displays the operation of 

25 fujictions. For example, if a user desired to copy a video sequence from a video 
optical disk onto a tape in a VCR, the user could separately control the optical disk 
player to play the sequence and control the VCR to record for a period of time. 
However, there would be no convenient means for the user to actually confirm that 
the desired operation was taking place other than to examine the displays on the 

30 control panels for the two devices to determine whether each device was separately 
performing the desired function. 

It would, therefore, be desirable to have an apparatus and a method for 
displaying the topology of a network as part of a user interface so as to provide a 
means for a user to monitor and control the devices in the network. 
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In most modem computer systems an operating system provides a 
graphical interface tor the computer user. The user can run applications programs, 
manipulate files, and perform most other necessary functions through this 
graphical interface by manipulating images on the computers display. This 
5 manipulation is accomplished by using cursor control keys and other keyboard 
keys or by using a cursor controlling peripheral device such as a joystick, mouse 
or trackball. 

In such systems, when a program or applications is loaded into the system 
it is frequently represented on the display by a small graphical image or icon which 

10 identifies the program to the user. For example, a word processing program might 
be represented by a graphical image of a piece of paper having lines of text on it 
and a writing instrument such as a pencil or pen. This is particularly so if the 
program has been removed from the screen and is running in the background. On 
a multitasking computer, several programs or applications can be running at once. 

15 each of which would be represented by its own graphical image. 

When a new device is coupled to the computer system it is not always 
represented graphically on the interface. For devices that are controlled by 
software loaded on and run by the computer system, a graphical image or icon is 
usually displayed somewhere on the interface or in a pull-down menu. This 

20 graphical image or icon for display is usually selected by the user when the 
software is loaded. In other systems, the image or icon is displayed under the 
control of the loaded software. For devices that are coupled to and work in 
conjunction with, but are not controlled by, the computer system, a graphical 
image or icon may not be displayed on the interface. 

25 It w ould, therefore, be additionally de$irable to have an apparatus and a^ 

iTiethod for displaying the topologyjCLf a network part of a graphicaj user 
interface to provide the meaiis mentioned above for a user do jiioni operate and? 
control the deyices in the network. 

SUMMARY OF THE INVENTION 
30 Accordingly, in one embodiment, a topology map for a digital system is 

generated and displayed on a display device to indicate the various components 
which make up the system. ^The various components are indicated using icons, 
each of which represent a respecti ve one of the components. A user specifies a 
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source device and a receive device by manipulating the corresponding icons so as 
to cause a data transfer between the source de\ ice and the receive device. The data 
transfer may include the transfer of video data, audio data, or both. In a preferred 
embodiment, the digital network corresponds to the IEEE 1394 Serial Bus 
3 Standard. 

In an alternate embodiment, when a device is added to the serial bus a 
graphical image representing that device is automatically displayed in a graphical 
user interface. Similarly, when a device is removed from the serial bus, the 
graphical image representing that device is grayed out, leaving a shadow of the 

10 graphical image until the device is either re-coupled or the system is powered off. 
Aliemaiively, the application can be implemented to remove the device from the 
graphical user interface as soon as that device is removed from the serial bus. In a 
further altemate embodiment, the device is also grayed out within the graphical 
user interface when the device is powered off. but remains coupled to the serial 

15 bus. Tasks performed by the devices coupled to the serial bus are also controlled 
and monitored l>y the user through the graphical user interface of the computer 
^ysterij. In order to control such tasks, a cursor control devices is used to choose 
options displayed in the graphical user interface. 

In a further altemate embodiment, one or more task windows are included 

20 in the interface which help the user select the task to be performed. Once selected, 
controls, commands and data related to the task arc displayed within a control 
display window of the graphical user iniert'ace. When a task requires data to be 
sent between devices, the flow of data between the devices over the serial bus 
network is graphically represented by an animated data stream within the graphical 

25 representation of the bus structure. When the data stops flowing between the 

devices, the animated data stream disappears. When a device is added to the serial 
bus, an animated stream of data temporarily flows between the graphical image of 
the new device and the computer system. 

There are many advantages provided by the present invention. For 

30 example, a user may view a connection map or an exact topology map for the 

digital system on the display device. Additionally, a user may control data transfer 
in the digital network by clicking icons or selecting commands from pop-up menus 
associated with the various components which make up the network. By ujing the> 
graphical user interface \yay, remote control of the various compoiients of 



|heidigiiaKficiv\'^)fk^ a user may understand signal flows 

within the network and can also view inlormaiion associated with each of the 
devices in the network by viewing the topology map displayed on the display 
device. 

These and other features and advantages of the present invention will be 
apparent to those skilled in the an upon review of the detailed description and 
accompanying drawings which follow. 

BRIEF DESCRIPTION OF THE DRAWINGS 

The present invention is illustrated by way of example and not limitation in 
the figures of the accompanying drawings in which: 

Figure I illustrates a digital network according to one embodiment of the 
present invention; 

Figure 2a illustrates an integrated receiver decoder fIRD) configured 
according to one embodiment of the present invention; 

Figure 2b illustrates the main block of the integrated receiver decoder: 

Figure 3 is a flow diagram illustrating the process of generating a topology 
map according to one embodiment of the present invention; 

Figure 4 illustrates an exemplary self identification packet format; 

Figure 5 illustrates a self identification packet table of the network shown 
in Figure 1; 

Figure 6 illustrates an exemplary connection map of the network illustrated 
in Figure I : 

Figure 7 illustrates an exemplary topology map of the network illustrated in 
Figure i; 

Figure 8 is a flow diagram illustrating the process of constructing a 
topology map; 

Figure 9 illustrates a modified packet table of the network shown in Figure 

I; 

Figure 10 illustrates an exemplary graphic user interface implementation of 
the present invention; 

Figure 1 1 illustrates a pop-up menu method of an exemplary user interface 
of the present invention: 
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Figure [2 illustrates the display of signal flow information between devices 
in a network on a graphically displayed network map; 

Figure 13 illustrates the retrieval of device information from a component 
of an audio-video system according to one embodiment of the present invention: 
5 Figure 14 illustrates a graphical user interface according to a further 

embodiment of the present invention; 

Figure 15 further illustrates a graphical user interface according to a further 
embodiment of the present invention after an additional device is added to the serial 
bus network; 

10 Figure 16 illustrates a printing video frames task displayed within the 

control display window of the graphical user interface; 

Figure 17 illustrates an accessing a music library task displayed within the 
control display window of the graphical user interface; and 

Figure 18 illustrates a computer system on which the graphical user 
15 interface of the present invention is implemented. 

DETAILED DESCRIPTION 

A method and an apparatus for providing device monitoring and control 

with a topology map in a network are disclosed. The present invention is 

applicable to any network which is capable of providing topology information. A 
20 digital network corresponding to the IEEE 1394 Serial Bus Standard will be 

described herein as an exemplary network within which the methods and apparatus 

of the present invention operate. 

In the following detailed description, the terms "topology map" and 

"connection map" have different meanings. ,^A topology map represents the exact| 
25 ^topology ol* a network and indicates the interconne^^^ ^ ^ 

devices. In contrast, a connection map includes device icons or names, but does 5^ ConntJwn 

not necessarily represent the exact topology of a digital network: Further 

distinctions between these terms will be apparent from a review of this entire 

specification. A connection map is sufficient for jhe piuposes of the present 
30 itivientioh as a user need not necessarily, know the exact topology of a network" in 

order to operate the devices which make up the network. The use of a topology 

map as described below is, therefore, optional. 
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Figure I illustrates a digital network 100. Network 100 corresponds to the 
IEEE 1394 Serial Bus Standard. A digital satellite system integrated receiver 
decoder (DSS IRD) 101 is connected to TV (ieIevision)/audio set 104 with an 
analog cable 102. In one embodiment, IRD 101 may obtain topology information 
5 and generate a map from the topology information. In an alternate embodiment, 
TV/audio set 104 may obtain the topology information and generate a map from 
that information if TV/audio set 104 has IEEE 1394 Serial Bus Standard interface 
capability and is connected to network 100. IRD 101 is also couple to various^ 
devices in network 100 including digital video discJOVD) player 110. digital 
10 video cassette recorder 1 (DVCR 1 ) 112, mini-disc (MD) recorder 1 20 and DyGR2 
122. ^ 

Those skilled in the an will appreciate that each of the devices lOL 1 10, 
1 12, 120, 122 of the network 100 is associated with a corresponding node of the 
serial bus. In general, the device to which a node is coupled acts as the "local 

15 host" for that node. For example, the DSS IRD 101 is the local host for the DSS 
IRD node: the DVD player 1 10 is the local host for the DVD node; DVCRl 1 12 is 
the local host for the DVCRl node: the MD recorder 120 is the local host for the 
MD recorder node; and DVCR2 122 is the local host for the DVCR2 node. It is 
not necessary for every node to have a local host, nor is it necessary that the local 

20 host always be powered. 

A point-to-point link such as cable 108 is used to connect two nodes to one 
another. The DSS IRD node is coupled to the DVCRl node by cable 108 and to 
the DVD node by cable 106. The DVCRl node is coupled to the MD recorder 
node by cable 1 16 and to the DVCR2 node by cable 1 18. The MD recorder node 

25 is capable of being coupled to other peripherals (not shown) by cable 1 14. Each 
of the cables 106, 108, 1 14, 116 and 1 18 may be consuucied in accordance with 
the IEEE 1394 Serial Bus Standard and may include a first differential signal pair 
for conducting a tlrst signal, a second differential signal pair for conducting a 
second signal, and a pair of power lines. 

30 Each of the nodes may have idenucal construction, although some of the 

nodes can be simplified because of their specific functions. Thus, the nodes can 
be modified to meet the needs of the particular local host. Each node has one or 
more ports, the number of which is dependent upon its needs. For example, the 
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DSS IRD node, as illustrated, has two ports, while the DVD player node has only 
one port. 

Figure 2a further illustrates the DSS IRD 124. Antenna 130 receives a 
signal 128 from a satellite 126. Signal 128 is amplified in a low noise block 
3 ( LNB) and transmitted to tuner 1 32. Those skilled in the art will appreciate that 
the signal transmitted to tuner 1 32 comprises a number of individual channels. In 
tuner 132, the desired channel from signal 128 is selected for processing and 
passed to demodulator 134. In demodulator 134, the pre-selected channel is 
QPSK-demodulated, viterbi-decoded. de-interleaved and Reed-Solomon decoded. 

10 The decoded signal 136 is then passed to main block 138 for further processing. 

Main block 138 is further illustrated in Figure 2b. As shown, decoded 
signal 158 is first parsed in Transport Packet Parser (TPP) 164 and then decrypted 
in DES engine 166. The resulting signal is then stored in an external RAM 160 
under the control of traffic controller (TC) 168. 

15 In response to signals from central processing unit (CPU) 1 82. the stored 

signal Ls retrieved from external RAM 160 and transmitted via traffic controller 168 
to either MPEG video decoder 180 or MPEG audio decoder 188. as appropriate. 
The output signal from video decoder 180 is mixed with on-screen display (OSD) 
data 174 and converted to NTSC or PAL analog signals by NTSC/PAL encoder 

20 1 70 and transmitted to TV/audio set 104. Digital audio signals are transmitted 

from the Audio Decoder 188 to Audio DAC 144 and converted to analog signals. 
The analog signals are then transmitted to TV/audio set 140. 

Central processing unit (CPU) 182 controls all of the above processes. 
CPU 182 conmiunicaies with on-chip RAM 176, ROM 184, extension bus 190 

25 and traffic controller 168 through an internal high speed bus 172. CPU 172 also 
communicates with ROM 192, modem 196 and remote command unit interface 
(RCU-IF) 194 through extension bus interface 178 and extension bus 190. RCU- 
IF 194 receives commands from a remote control unit (RCU) (not shown) and 
transmits them to CPU 182 via extension bus 190. |-ink layer IC (LINK) 198 and^ 

30 physicaljayer IC (PHY) 200 communicate with CPU 1 82 through extension 

interface bus 178 and extension bus 190. PHY 200 is coupled to LINK 198 yja 
data and control lines and to other nodes of the IEEE 1394 Serial Bus as indicated. 

LINK 198 and PHY 200 make up the IEEE 1394 Serial Bus interface for 
DSS IRD 124. All 1394 commands transmitted by CPU 182 are transferred to 



LINK 198 through extension bus 190. The 1394 commands are sent via PHY 
200 and are ultimately transmitted to a destination node in the network 100. Tlic^ 
commands from other devices in network lOOdf Figure 1 are received by PHY 
200 and transmitted to LINK 198. jPISK* 1 98 transfers these commands to CPU 
182 through extension bus 190.f Audio- video data is transferred between DSS 
IRD 124 and LINK 198 through 1394 data bus 186. When DSS IRD 124 sends 
data. TC 168 transfers the data from external RAM 160 or DES engine 166 to 
LINK 198. When IRD 1 24 receives data, LINK 198 sends the data to TPP 164 
via 1394 data bus 186. 

Figure 3 is a flow diagram illustrating the general steps followed by the 
present invention in constructing a topology map. There are several steps 
followed in configuring a cable environment, namely, bus initialization, self 
identification and device idenufication. In step 202, bus initialization is 
performed. Upon start up and again whenever a new node joins network 100, a 
reset signal forces all nodes in network 100 into a special state which clears all 
topology information and starts the next phase. During the bus initialization 
phase, PHY 200 internally latches the connection status of each port. PHY 200 
will automatically initiate the bus initialization phase if the connection status of any 
port changes, for example, where an adjacent device is removed or added. In 
1 394 parlance, nodes with no connected ports are isolated. Nodes with a single 
connected port are leaves (or children) and nodes with two or more connected 
ports are branches (or parents). The eventual root node may be either a branch or 
a leaf. 

In step 204, the tree identification phase is performed. During this phase, 
a tree identification process translates the general network topology into a tree 
where one node is designated as the root node and all of the physical connections 
have a direction associated with them pointing towards the root node. Each 
connected port of each node may be labeled as a parent port (connected to a node 
closer to the root) or as a child port (connected to a node further from the root). 
The unconnected ports are labefcd-^'off and danot participate-further iirthe- 
arbitration process. The tree identification process is well known in the art. 

In step 206. to give each node an opportunity to select unique physical 
identification arid identify itself to any management identity attached to the bus, th^ 
self identification phase is performe(|? This phase allows low level power 
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management and the building of the system topology map. This process is also 
well known in the art. During the self identification process, all nodes identify 
themselves to all other nodes. An exemplary self identification packet format is 
illustrated in Figure 4, 

During self-identification step 206. each node receives a self identification 
packet from all the nodes in the network 100. CPU 182 in DSS IRD 124 receives 
these packets from LINK 198 and stores portions of the information them in a self 
identification packet table in external RAM 160. Only the physical idendfication 
(PHY-ID) and port status bits of each self identification packet are needed to 
construct a map in accordance with the present invention. 

Figure 5 illustrates an exemplary self identification packet table 2 1 8 for the 
network 100 shown in Figure I. In the table 218, the term "parent" identifies a 
parent node, that is a node which has a port status of 10 (see Figure 4. indicating 
the pon status bits pi. p2, etc.). The term "child" identifies a child node, i.e.. a 
node which has a port status of 1 1, the term "UNCONN" indicates that the 
particular port is not connected to any other PHY and the pon status is OK and 
finally, the term "NOPORT" indicates that the particular port is not present on this 
particular PHY and the port status is 00. The device name column of table 2 1 8 is 
filled in during step 208. 

Returning to Figure 3, step 208, after the self identification process, a 
device identification process is perfonAed. During this process 208. DSS IR® 
I24.sends commands to all the nodes and inquires as to their respective devic^ Xks\^ 
types. Device type information may be stored in and returned from a configuratioji 
KOM associated with each node of the serial bus as is known in the art^ 

According to the responses from the nodes, DSS IRD 124 associates 
unique device names to the nodes automatically. For example, a DVCR will be 
named "DVCR". If multiple DVCRs are connected, a suffix will be attached to 
each of the device names as follows: DVCR I, DVCR2, etc. 

As the responses are received, the device name column of table 218 is 
filled in appropriately as shown in Figure 5. Instead of DSS IRD 124 - 
automatically assigning the device names, a user may also give the devices 
preferred names. 

In step 210 of Figure 3, each device is represented as an icon or a name on 
the map to be constructed. To construct the map, CPU 182 of DSS IRD 124 
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executcs commands so as lo place each icon suitably linked to other icons on the 
display ( i.e., the TV screen or other display device). 

Figure 6 illustrates an exemplary connection map of the network 100 
illustrated in Figure 1 . In the case of a topology map (in contrast with a 
5 connection map). CPU 1 82 of IRD 124 must construct the exact topology using 
the physical identifications and port status information stored in table 218. Figure 
7 illustrates an exemplary topology map of the network 100 illustrated in Figure I. 

The graphical displays shown in Figures 6 and 7 illustrate the use of icons 
to represent the various components of network 1 00. ^he ic ons arejisptaYe.d 
10 usins proerammins techniques well known in the art and. as discussed further^ , \ lajcU 

" " V - ' (jj:\rv\ 

below, provide a user with a graphical inter^^^ by which the user can control ihe^ 
dpemtiori of the yan^ will be appreciated that the graphical 

illustrations for the various devices could be any of a number of fanciful 
illustrations. loddition, simple tex^ in place of the graphical ,:^ivai 



1 5 Hlustratjons^ Ay here, graphical icons are.used, the jcons rnaybe animated^For 
example, when DVCRl is operating, the icon representing DVCRl may depict 
movement of the video tape which is shown on the graphical icon. 

Figure 8 is a flow diagram illustrating the general steps followed by CPU 
182 in modifying table 218 of Figure 5 in order to construct a topology map for 

20 display. In step 228, child identification counter CID is initialized to 0. At step 
230, counter CID is tested to determine whether it has exceeded the maximum 
physical ID (phy_ID) value for the table 218. In this example, the nodes of 
network 100 have phyJD values of 00 (DVD player 1 10), 01 (MD recorder 120). 
02 (DVCR2 122). 03 (DVCRl 1 12), and 04 (DSS IRD 101). The phyJD values 

25 ore derived from the node seif-identification packets transmitted during the self- 
identification process discussed above. If the CID counter exceeds the maximum 
phy_ID value, all of the cells of table 218 have been tested, as described below, 
and the process ends at step 232. 



30 for table 218. In this example, the maximum port number is 3, however, those 
skilled in the an will appreciate thai the maximum port number may vary 
depending upon the configuration of network 100 and the nodes comprising same. 
The two counters. CID, and Cpon, are used as place holders to define a cell-by- 
cell search of table 218. 




At step 234, a second counter, Cport, is set to the maximum port number 
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The search begins at step 236 where a test of the cell defined by CFD and 
Cport is conducted. For the present example, the first cell tested is cell 214. This 
is because CID is set to 0 initially and Cport is set to 3 initially. CID represents the 
row of table 2 18 to be searched and Cport represents the column to be searched. 
5 The intersection of the row defined by CID and the colunin defined by Cport 
defines the cell to be tested at step 236. The test of step 236 determines whether 
the current cell is a "child" cell. That is, the test determines whether the port, 
defined by Cport, of the node, defined by phy_ID or CID, is a child port. For the 
first cell 2 14, the test will result in a negative condition and the process moves to 
10 step 240. 

At step 240. a check is made to determine whether a cell in column 1. e.g., 
cell 212, is under test. If not, the process moves to step 246 and the counter Cport 
is decremented. If, however, the current cell under test is in column 1 , the counter 
CID is incremented. In this way, cells of table 218 are tested by moving across a 

15 row, defined by CID, from maximum port number to minimum port number. 
After the cell in column 1 of the row of interest is tested, the process selects the 
cell in colunm 3 of the next highest CID row for testing. So, after cell 212 is 
tested, cell 2 16 is tested next. This process continues until a child cell is found at 
step 236. It is apparent that cell 226 will be the first such child cell found. Cell 

20 226 represents port number 3 of DVCR 1 . 

When a child cell of table 218 has been found, the process moves to step 
238 and a third counter, PID, is set equal to the current value of CID minus 1. 
Thus, when cell 226 is found, PID will be set equal to 2 (CID=3-1). 

Next, at step 242, a fourth counter, Pport, is set equal to the maximum 

25 port number (again, for this example the maximum port number is 3). The two 
counters, PID and Pport, will be used as place holders for a second search of table 
218. The goal of this second search will be to find the matching "parent" cell of 
table 2 1 8 for the child cell found in step 236. 

The search for the matching parent cell begins at step 248 where the cell 

30 defined by the current values of PID and Pport is tested. PID defines the row 
under test and Pport defines the column under test. So, continuing the above 
example, after cell 226 is identified as a child cell, PID will be set to 2 and Pport 
will be set to 3. thus defining cell 222. Cell 222 is tested at step 248 and 
determined not be a parent cell. Hence, the process moves to step 250. 
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Ai step 250, a check is made to determine if the counter Pport is currently 
equal to I . If not, the process moves to step 254 and Ppon is decremented by I . 
If the current value of Pport is equal to I . the process moves to step 256 and the 
value of PID is decremented by I . In this way, the table 2 18 is searched cell-by- 
5 cell moving across each row from right-lo-left and moving upwards in the table 
after the last cell in a row (i.e., the cell in column 1 ) is tested, li is apparent that a 
search of this type will result in cell 220 being identified as the first parent cell 
found. 

When a parent cell is found at step 248, the process moves to step 252. At 
10 step 252. the child cell found in step 236 is modified. In particular, the term 

"child" is removed and in its place CPU 182 writes in the corresponding values of 
PID and Pport. That is, the cell is annotated with the Phy_ID and Port numbers of 
its corresponding parent in network 100. The process then moves to step 258 and 
the term "parent" is removed from the cell identified in step 248. In place of 
15 "parent". CPU 182 writes in the values of CID and Cport. That is, the cell is 

annotated with the Phy_ID and Port numbers of its corresponding child in network 
100. 

In this way, all of the parent and child cells of table 500 are modified to 
reflect the proper Phy_ID and port numbers of their respective child and parent 
20 nodes. The fully modified table 260 is shown in Figure 9. Note that cell 264 of 
table 260 corresponds to cell 226 of table 218. Similarly, cell 262 corresponds to 
cell 220. 

Using the information contained in table 260, CPU 182 draws in the 
appropriate connections between nodes so as to produce a topology map (as 

25 opposed to a connection map) on the display. That is, icons representing the 
various devices of network 100 are drawn in as before. However, rather than 
merely drawing a connection map, (which shows logical connection of various 
components) as shown in Figure 6. a topology map, (which shows physical 
connection of various components) such as that shown in Figure 7, can be drawn 

30 because CPU 182 now has the appropriate information in terms of Phy_ID and 
Port number to allow for a precise reproduction of the network's actual topology. 
For the network 100 of Figure 1, a connection will be drawn in between port 1 of 
D VCR2 and port 3 of DVCR 1 . Note that cells 264 and 262 contain information 
which allows for such a connection to be identified. The entire topology map of 
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Figure 7 is drawn in this way with the exception of the known analog connection 
between DSS IRD 101 and TV/audio set 104. 

Figures 10 and 1 1 illustrate exemplary graphic user interfaces of the 
present invention. In response to a user command, CPU 182 of DSS IRD 101 
5 con.structs a connection map or a topology map as described above and stores it in 
external RAM 176. Hereafter, it is assumed that a connection map is used 
although the methods to be described are equally applicable to the use of a 
topology map. The map data is sent to the OSD block 174 through TC 168 and 
mixed with the decoded video signal. Tlie nriixed signal is converted to_NTSC or^ 

10 PAL and sent to TV/audio set 104. The connection map can be superimposed o\:er^ 
the tdevision-video on the TV/audiO set 1 04. 

Figure 10 shows how a user can control the operation of network 100 
devices using the connection map. Assume the user wants to record the 
information played out from DVD player 1 10 onto a videotape in DVCR 1112 and 

15 at the same time play a videotape in DVCR2 122 through DSS IRD 101 on 
TV/audio set 104. There are two ways to specify each source node and its 
corresponding receiver node. 

For example, in Figure 10. a drag and drop implementation is illustrated. 
A user selects the icon 280 associated with DVD player 1 10 and drags it toward a 

20 receiver icon using cursor 284. In the example shown, the DVD icon 280, which 
is highlighted, is dragged and dropped to the DVCRl icon 282. The select and 
drag and drop operations are performed using a cursor control device such as an 
infrared remote control. In response to these operations, CPU 182 of DSS IRD 
101 sends a play command to the DVD player 1 10. The DVD player 1 10 responds 

25 by beginning to play output data into the network. The CPU 1 82 also sends 
commands to DVCRl 112 to record the data from the DVD player 1 10./ The 
commands are generated and transmitted through network 100 in accordance \yith 
the IEEE 1394 Serial Bus Standards 

In the same way, in order to play back data from DVCR2 122, a user drags 

30 and drops the DVCR2 icon 276 to the DSS IR&icon-266 or the TV icon 268. The 
DSS IRD 101 and the TV set 104 are connected by an analog cable. In the map, 
they are regarded as the same node. Note also that a user can specify more than 
one receiver device. For example, u user can record DVD signals to both DVCR 1 
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and DVCR2 by dragging and dropping the DVD icon 270 to both DVCRl and 
DVCR2 icons 274 and 276. 

, A second mcthod^^^ illustrated in Figure I I and referred P 

to as the pop-up menu rnethpd. When a user selects the DVD player icon 270. a 
5 pop-up menu 286 appears. If a PLAY button is selected from the pop-up menu 
286 using cursor 284, the DVD player 1 10 begins to play. In the same way. to set 
DVCR 1 1 1 2 to record, a user may .select a REC button from a menu associated 
with DVCRl icon 274. DVCR2 1 12 and DSS IRD 101 may be similarly 
controlled. 

10 The drag and drop rnethod jllustrated ih-Eigure^lOJs a sinripler method ip \)rv-^ 

sicunccprding o backjhowyer.^ ^ 
Jorwiml. re,\^^ 

method illustfated in^Figure 11? 

Figure 12 illustrates the display of signal flow information between devices 
15 in network 100 illustrated by a connection map. Signal flows are indicated with 
arrows 294 and 292. For one embodiment, these arrows may be different colors 
to indicate different information. The arrows can be animated during play and/or 
search and may flash on and off during a pause. If recording or playback is 
halted, the arrows disappear. Arrows such as 294 and 292 are implemented using 
20 programming techniques well known in the art. 

Figure 13 illustrates how device iMqrrnation may be retrieved using the 



connection map implementation of the present invention. If an INFO button 3 lO^is 
selected ftpm a po^^^ associated with pyCR2 icon 304* DSS IRD 101 

transmits a command to DVCR2 122 to send information regarding the video tape 
25 being played. DVCR2 122 returns the tape information. The information will 
then appear in a window 302 on the screen as illustrated in Figure 13. The 
contents of the information window 302 depends on the device selected and its 
leatures. Examples of device infonnation indude:^ tinje. 

total playback/recording time, etc.); title (name of the loaded tape or disk); write * 

. .... . ■ ... ^ 

30 protection (on or ofO: and play mode (long play or standard play.). 

When a device js added to the serial bus network, a graphical irnage cJJisJ^ 
representing jhat device i^dynamiially ^displayed on the graphicaj^user interface. L%^^ 
SirruLarly, when a device is rcmoved^from the sen the graphical image 
representing that device is grayed out in the graphical user interface. In the ^^^^^^ 
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prcferred ernbodimenl, the shadow of the graphical image remains and if the 
device is again added to the serial bus. the full color of the graphical image is 
reinstated. When the system is powered off and then powered on. only those 
de\'ices actually coupled to the serial bus arc displayed within the graphical user 
5 interface. Accordingly, when a device is removed from serial bus, the graphical 
image representing that device is grayed out and then removed when the system is 
powered off and then powered back on, if the device was not re-coupled to the 
serial bus. Alternatively, the graphical image is removed as soon as the device is 
removed from the serial bus. In a further alternate embodiment, the graphical 

10 image is also grayed out when the device is powered off, but remains coupled to 
the serial bus. signalling to user of the graphical user interface that the device is 
currently unavailable. 

Figure 14 illustrates a third method of device control. Here, a graphical 
user interface 320 includes a bus display window 338 and a control display 

15 window 322. The bus display window 338 displays the devices which are 

coupled to the serial bus network. A graphical representation of the bus structure 
340 is shown connecting each of the represented devices together. This graphical 
representation may be a topology map or a connection map as discussed above. A 
computer, on which the graphical user interface is displayed, is coupled to the bus 

20 stmcture. In the bus display window 338 of the graphical user interface 320, a 
graphical representation of the computer 336 is shown connected to the graphical 
representation of the bus structure 340. Also shown connected to the bus structure 
340 are compact disk (CD) changer 334, a magnetic disk (MD) recorder 332, a 
stereo amplifier 330. a television 328, a video printer 326 and a digital cassette 

25 recorder (VCR) 324. It will be readily understood that this collection of devices 
on the bus is exemplary only and in no way is intended to limit the scope of this 
invention or the claims appended hereto. 

Cpiranutucauoris are directed to the user through the control display# 
w^mddw 322. Tlie user als;o entisrs control comitumds and chooses options fooa 

30 current task through the control display window 322? A user enters the control 
commands and choose the options using a cursor control device. Tasks available 
to be performed and controlled through the graphical user interface are displayed in 
the task windows 312, 314, 316 and 318. A user chooses a task to be performed 
using the cursor control device. Once chosen, a current task is displayed in the 
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conlroi display window 322. The task windows 312, 314. 316 and 318 
preferably display generic tasks based on the general capabilities of the system. 
Alternatively, the task windows 3 12, 3 14, 3 16 and 3 1 8 display specific tasks 
based on the type of devices coupled to the serial bus network and the capabilities 
5 of those devices. As should be apparent to those skilled in the art, the scope of the 
present invention is not limited to the number of tasks herein described for display 
within the interface. Depending on the system, any appropriate number of tasks 
can be displayed within the interface. 

Figure 15 demonstrates the change in the graphical user interface 350 when 

10 an additional device is connected to the serial bus network. When the digitaj 
camcorder is first coupled to the seriarbus network, a conununication is sent^ 
across the serial bus identifying the type of device that has just been coupled tplhe 
serial bus and the address of the device*. The host system displaying the graphical 
user interface 350, receives that conununication and determines that a new device 

15 has just been coupled to the serial bus, in this example a digital camcorder. /Th^ 
host system then obtains an image for the digital camcorder from an image library. 
The image library is maintained in the host computer system's nrtemory and 
contains images of different devices that could be coupled to the serial bus. ^ 
Alternatively, the computer system will obtain the image of |he: device from the^ 

20 memory of the device itself . The image of the digital camcorder is then displayed 
within the bus display window 370 as the graphical representation of the digital 
camcorder 368. 

When the graphical representation of the digital camcorder 368 is first 
displayed within the bus display window 370, an animated data stream 374 is 

25 illustrated within the representation of the bus structure 370. between the graphical 
representation of the digital camcorder 368 and the graphical representation of the 
host computer system 366, representing the initializing communicadon between 
the two devices. The graphical representation of the digital camcorder 368 will be 
displayed within the bus display window 370 in full color, as long as the digital 

30 camcorder is coupled to the serial bus network. 

If the digital camcorder is removed from the serial bus network, the 
graphical representation of the digital camcorder 368 is grayed out, leaving a 
shadow or oudine of the digital camcorder. If the digital camcorder is then re- 
coupled to the serial bus network before the system is powered off, the graphical 
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represeniaiion of the digital camcorder 368 is reinstated in full color. If the system 
is powered off before the digital camcorder is re-coupled to the serial bus network, 
then the graphical representation of the digital camcorder 368 is removed, when 
the system is again powered on. In an alternate embodiment, the graphical 
representation of the digital camcorder 368 is removed as soon as the digital 
camcorder is removed from the serial bus network. In a further alternate 
embodiment, the graphical representation of the digital camcorder 368 is grayed 
out if the digital camcorder is powered off and is still coupled to the serial bus 
network. This demonstrates to the user that the digital camcorder is coupled to the 
serial bus network, but is currently unavailable. 

Figure 16 illustrates how a currently selected task, chosen by the user, is 
displayed within the control display window 392 in the graphical user interface 
386. The chosen current task illustrated in this figure is the task of printing video 
frames from the digital camcorder on the video printer. A user chooses this task 
by selecting the printing video frames task, within the task window 376, using the 
cursor control device. When a particular task is chosen the button corresponding 
to the task is highlighted. When a current task is displayed within the control, 
display window 392, the control display window 392 includes a device 
subwindow 388, a conrunands subwindow 394 and a task control subwindow 
396. The graphical representation of the device to be used to complete the task is 
displayed in the device subwindow 388. In the printing video frames task 
displayed in Figure 3, the graphical representation displayed within the device 
subwindow 388 is the graphical representation of the video printer. 

The commands to be chosen by the user are displayed within the 
commands subwindow 394. In the printing video frames task displayed in Figure 
1 6, the conmiands available to the user are start, print and dubbing. A user selects 
one of the commands in the commands subwindow 394 using the cursor control 
device. Not all of the displayed commands are available for selection at all times. 
When available for selection, a command is highlighted, as is the start command 
390. 

The task control subwindow 396 displays the options available to the user 
for completing the task. In the printing video task displayed in Figure 16. video 
frames from which the user can select for printing are displayed in a frame 
window 398 within the task control subwidow 396. The video frames to be 



wo 97/49057 



PCT/US97/11526 



-19- 

displayed arc read from a video source, in this case the digital camcorder. The 
displayed video frames occur at a predetermined interval on the tape within the 
digital camcorder Preferably, in the printing video frames display in this figure, 
the video frames are displayed in one second intervals within the frame task 
5 window 398. The user can scroll through theses video frames using the control 
selection options 402. displayed within the task control subwindow 396. The user 
selects one of the control selections 402 using the cursor control device. The 
video frames will then be displayed at one second intervals ai a rate and in an order 
based on the control selection option chosen by the user, e.g., play, fast forward, 

10 rewind, stop and pause. 

The user selects one or more of the video frames displayed within the 
frame window 398 for printing using the cursor control device. In the example 
illustrated in Figure 16. the user has selected the video frame 398. Once selected, 
the video frame 398 is first displayed within the selected frame window 384 and 

15 will be printed once the user enters the print command from the commands 
subwindow 394. 

When a video frame is being primed and data is being sent from the digital 
camcorder to the video printer, an animated su^am of data 424 is illustrated within 
the representation of the bus system 422. The animated stream of data 424 is 
20 shown flowing from the graphical representation of the digital camcorder 418 to 
the graphical representation of the video printer 406. This animated stream of data 
424 allows a user to monitor the operation of the devices coupled to the serial bus 
network. 

Figure 17 displays a currently selected task of accessing a music library 
25 within the control display window 446 in the graphical user interface 438. The 
task of accessing a music library allows a user to play a CD stored within the CD 
changer through the stereo amplifier. A user chooses this task by selecting the 
accessing a music library task, within the task window 430, using the cursor 
control device. The graphical representation of the CD changer is displayed within 
30 the device subwindow 440. The comnunds subwindow 450 includes play, pause 
and stop commands as well as slidable controls for volume, bass and treble, which 
are selected and conu*olled by the user using the cursor control devices. In the 
accessing a music library task, displayed in Figure 17, available music CDs are 
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Jisplayed in a CD window 452. A user scans through the available music CDs 
using the control selection options 434 and the cursor control device. 

A user selects one of the CDs displayed in the CD window 452 using the 
cursor control device. Once selected the title of the CD is displayed in an Album 
5 Name subwindow 436. In the example illustrated in Figure 17, the selected CD is 
the CD 444. The titles of the available songs on the selected CD are displayed in 
the Song List subwindow 448. From the Song List subwindow 448. a user can 
select songs to be played using the cursor control device. The selected songs to be 
played are listed in the selected order in the Play List subwindow 454. 

10 When a song from a CD is being played and data is being sent from the CD 

chanter to the amplifier, an animated stream of data 474 is illustrated within the 
representation of the bus system 478. The animated stream of data 474 is shown 
flowing between the graphical representation of the CD changer 466 and the 
graphical representation of the stereo amplifier 462. 

15 In the example illustrated in Figure 17, a task of dubbing a video has 

previously been initiated by a user. This task involves taking the selected parts of 
the tape in the digital camcorder and copying onto a tape in the digital VCR while 
simultaneously playing the video on the television. This task is being completed at 
the same time the selected CD is being played. Accordingly, there are two 

20 simultaneous animated data streams flowing within the representation of the serial 
bus network 478. The animated data stream 474 is shown flowing between the 
graphical representation of the CD changer 466 and the graphical representation of 
the stereo amplifier 462 for the playing the CD task. An animated data stream 476 
is shown flowing between the graphical representation of the digital camcorder 

25 470. the graphical representation of the digital VCR 456 and the graphical 

representation of the television 460 for the dubbing video task. Once the task is 
complete and the data stops flowing between these devices, the animated data 
stream 476, of the graphical user interface will disappear. 

CThe.graphical user interface of the present invention allows a user to j> 

30 control and monitor the operation of devices preferably cpiipled together by an 
IEEE 1394 serial bus network. It should be apparent that the graphical user 
interface of the present invention can also be used to control and monitor devices 
coupled together in other types of networks.^ The bus display window 472 within 
the graphical user interface displays the devices coupled to the serial bus network. 
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When a device is added to the serial bus network a graphical representation of thai 
device is displayed within the bus display window 472. When a device is 
removed froni the serial bus display window 472, leaving a shadow of the 
graphical representation until the device is either re-coupled or the system is 
5 powered off. A graphical representation of the serial bus coupled to the devices is 
also illustrated in the bus display window 472. When data flows between devices 
on the serial bus network, an animated stream of data flows between the graphical 
representation of those devices, within the representation of the serial bus 
network. Accordingly, a user can monitor the activity and data communications 
10 on the serial bus network through the graphical user interface of the present 
invention. 

The control display window 446 is used to communicate with the user and 
to allow the user to make selections and control the operation of the devices 
coupled to the serial bus network. The task windows 426, 428, 430 and 432 

15 allow a user to select a task for display in the control display window 446. 

The graphical user inteff ace is preferably displayed on a computer system. 
However, the graphical user interface is alternatively displayed on a television, 6^^- 
monitor or other system which coupled to the serial bus network and whicR 
includes a display devic^. In order to control and initiate tasks to be performed by 

20 the devices, a cursor control device is used by the user to choose options displayed 
on the graphical user interface. The cursor control device can be a mouse, keypad, 
trackball, remote control or other device, depending on the configuration of the 
host system. Further, the cursor control device can be wired or wireless using 
radio, infrared or any other appropriate technology. 

25 Figure 18 shows an exemplary computer system 484 on which the 

graphical under interface of the present invention is implemented. In Figure 18, 
the computer system 484 includes a central processor unit (CPU) 488, a main 
memory 492, a video memory 490, a keyboard 496 for user input, supplemented 
by a conventional mouse 498 for manipulating graphic images as a cursor control 

30 device and a mass storage device 500; all coupled together by a conventional 
bidirectional system bus 497. The mass storage device 500 may include both 
fixed and removable media using any one or more of magnetic, optical or 
magneto-optical storage technology or any other available mass storage 
technology. The system bus 497 contains an address bus for addressing any 
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. ponion of the memory 492 and 490. the system bus 497 also includes u data bus 
for iransterring data between and among the CPU 488» the main memory 492. the 
video memory 490. and the mass storage device 500. 

Coupled 10 a port of the video memory 490 is a video multiplex and shifter 
5 circuit 486, to which in turn a video amplifier 480 is coupled. The video amplifier 
480 drives a monitor or display 482 on which the graphical user interface of the 
present invention is displayed. The video multiplex and shifter circuitry 486 and 
the video amplifier 480 conven pixel data stored in the video memory 490 to raster 
signals suitable for use by the monitor 482. 

Thus a method and apparatus for device control with a topology 
map on a network have been described. Although features and examples of the 
present invention have been described with reference to specific exemplary 
embodiments thereof, those skilled in the art will appreciate that certain 
modifications may be possible without departing from the broader spirit and scope 
of the invention which should be limited only by the claims which follow. 
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CLAIMS 

What is claimed is: 

1 . A method, comprising the steps of: 
identifying nodes coupled to a bus; and 

generating a representation of an interconnection of the nodes. 

2 . The method of claim 1 wherein the step of generating a representation of an 
5 interconnection of the nodes further comprises the steps of: 

generating a topology map for the nodes, the topology map comprising 
node identification information, the topology map being stored in a memory: 

associating with the node identification information, corresponding local 
host identification information in a data structure in the memory; and 
10 displaying a connection map using the topology map and the local host 

identification information, the connecdon map including the local host 
identification information. 

3 . The method of claim 2 wherein the connection map further indicates 
physical connection paths between the nodes, 

15 4. The method of claim 2 wherein the connection map further indicates logical 
connection paths between the nodes. 

5 . The method of claim 1 further comprising the step of controlling the nodes 
using the representation. 

6 . The method of claim 5 wherein the step of controlling further comprises 
20 the step of initiating a transmission of information between a first node and a 

second node. 

7 . The method of claim 6 wherein the step of initiating a transmission further 
comprises the step of generating a representation of the transmission of 
information between the first node and the second node. 



25 



8 - The method of claim 7 wherein the transmission of informadon is 
represented by a plurality of arrows. 
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9 . The method of claim 6 wherein the step of initiating a transmission of 
information between the first node and the second node further comprises the steps 
of: 

selecting a corresponding representation of the first node; 
5 dragging and dropping the corresponding representation of the first node 

over a corresponding representation of the second of nodes. 

1 0. The method of claim 6 wherein the step of initiating a transmission of 
information between the first node and the second node comprises the steps of: 

selecting a corresponding representation of the first node; 
10 displaying a pop-up menu associated with the first node, the pop-up menu 

comprising a plurality of commands for the first node; and 

selecting a first of the commands from the pop-up menu. 

1 1 . The method of claim 5 wherein the step of controlling comprises the steps 
of: 

15 displaying one or more task windows, each for displaying potential tasks 

to be selected: and 

performing a task selected by using one or more of the nodes coupled to 
the bus. 

1 2. The method of claim 1 1 further comprising the step of displaying a control 
20 window including information and commands relating to a selected task and the 

nodes associated with that task. 

13. The method of claim 1 wherein the step of generating a representation is 
completed on a display of a computer system. 

14. The method of claim 13 wherein the computer system further includes an 
25 input device. 

15. The method of claim 14 wherein the input device is an infrared remote 
control. 

16. The method of claim 1 further comprising the step of: 
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deiecting an addition of a new node to the bus or a removal or powering 
off of one of the nodes coupled to the bus; and, 

generating a revised representation of the interconnection of the nodes 
coupled to the bus after the step of detecting. 

5 17. The method of claim 16 wherein the step of generating a revised 

representation of the interconnection of the nodes further comprises the steps of: 

generating a topology map for the nodes, the topology map comprising 
node identification information, the topology map being stored in a memory; 

associating with the node identification information, corresponding local 
10 host identification information in a data structure in the memory; and 

displaying a connection map using the topology map and the local host 
identification information, the connection map including the local host 
identification information. 

18. The method of claim 17 wherein the step of generating a topology map for 
15 the nodes comprises the step of updating an existing topology map. 

19. The method of claim 17 wherein the connection map further indicates 
physical connection paths between the nodes. 

20. The method of claim 17 wherein the connection map further indicates 
logical connection paths between the nodes. 

20 21. The method of claim 17 wherein the step of displaying a connection map 
using the topology map and the local host identification information comprises the 
step of displaying nodes that were removed from the bus or powered off 
differently than those that remain coupled to the bus and are powered on. 

22 . A method, comprising the steps of: 

25 identifying a plurality of interconnected audio/video components; and 

generating a representation of the interconnection of the audio/video 
components. 

23 . The method of claim 22 further comprising the steps of: 
displaying on a first of the plurality of audio/video components a 

30 connection map, the connection map indicating the interconnection of the plurality 
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of audio/video components, and including a plurality of representations, each of 
the representations corresponding to a respective one of the audio/video 
components. 

24. The method of claim 23 further comprising the step of initiating a 

5 transmission between a first audio/video component and a second audio/video 
component using the connection map. 

25 , The method of claim 24 further comprising the step of displaying on the 
connection map a representation of the transmission between the first audio/video 
component and the second audio/video component. 

10 26. The method of claim 25 wherein the transmission is represented by a 
plurality of arrows. 

27. The method of claim 24 wherein the step of initiating a transmission further 
comprises a drag and drop operation. 

28. The method of claim 24 wherein the step of initiating a transmission further 
15 comprises the steps of; 

selecting one of the representations: 

displaying, in response to the step of selecting, a pop-up menu, the pop-up 
menu comprising a plurality of commands, each of the commands corresponding 
lo an associated operating state of the audio-video component corresponding to the 
20 selected representation; and 

selecting a first of the conimands so as to cause the audio/video component 
corresponding to the selected representation to enter the operating state associated 
with the first command. 

29. The method of claim 24 wherein step of initiating a transmission further 
25 comprises the steps of: 

displaying one or more task windows, each for displaying potential tasks 
to be selected; and 

performing a task selected by using one or more of the interconnected 
audio/video components. 
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30. The method of claim 29 further comprising the step of displaying a control 
window including information and commands relating to a selected task and the 
audio/video components associated with that task. 

3 1 . The method of claim 22 further comprising the step of: 

5 detecting an addition of a new audio/video component to the plurality of 

interconnected audio/video components removal or a powering off of one of the 
interconnected audio/video components: and, 

generating a revised representation of the interconnection of the 
audio/video components. 

10 32. The method of claim 3 1 wherein the step of generating a revised 

representation of the interconnection of the nodes further comprises the step of 
displaying on a first of the plurality of audio/video components a connection map, 
the connection map indicating the interconnection of the plurality of audio/video 
components, and including a plurality of representations, each of the 

15 representations corresponding to a respective one of the audio/video components. 

33. The method of claim 32 wherein the step of displaying on a first of the 
plurality of audio/video components a connection map comprises the step of 
displaying representations of audio/video components that were removed from the 
plurality of interconnected audio/video components, or were powered off, 

20 differently than representations of audio/video components that reniain 
interconnected and are powered on. 

34. A system comprising: 
a bus; 

a memory coupled to said bus; and, 
25 a processor coupled to said bus and configured to generate connection 

information for a plurality of nodes of a network of which said processor is one 
component, said connection information for storage in said memory and for use in 
displaying a representation of said network. 

35. The system of claim 34 wherein said processor is associated with one of 
30 said nodes. 
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36. The system of claim 34 wherein said nodes are interconnected along an 
[EEE 1394 bus. 

37. The system of claim 34 wherein at least one of said nodes is associated 
with a mixer configured to receive video signals, the video signals representing 

5 data to be displayed on said display, the mixer funher configured to receive 
interconnection signals from said processor, the interconnection signals 
representing the interconnection of said nodes, and to mix the video signals with 
the interconnection signal to produce a mixed signal for display on said display. 

38. The system of claim 37 wherein said mixer comprises an MPEG video 
10 decoder and an on-screen display mixer. 

39. The system of claim 34 further comprising an interface unit. 

40. The system of claim 39 wherein said interface unit comprises an infrared 
remote control. 

4 1 . The system of claim 34 wherein the processor coupled to said bus and 
15 configured to generate connection information for a plurality of nodes of a 

network, of which said processor is one component, is further configured to 
generate revised connection information upon an addition of a new node to the 
network or a removal or powering off of one of the nodes of the network, said 
revised connection information for storage in said memory and for use in display 
20 of a revised representation of said network. 
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FOR THE PURPOSES OF INFORMATION ONLY 
Codes used to identify States party to the PCT on the front pages of pamphlets publishing international applications under the PCT. 



AL 


Albania 


ES 


Spain 


LS 


Lesotho 


SI 


Slovenia 


AM 


Anncnia 


F' 


Finland 


LT 


Lithuania 


SK 


Slovakia 


AT 


Austria 


. FR 


France 


LU 


Luxembourg 


SiN 


Senegal 


AU 


Australia 


OA 


Gabon 


LV 


Latvia 


sz 


Swaziland 


AZ 


Azerbaijan 


GB 


United Kingdom 


MC 


Monaco 


TO 


Chad 


BA 


Bosnia and Herzegovina 


GE 


Georgia 


MD 


Republic of Moldova 


TG 


Togo 


BB 


Barbados 


GH 


Ghana 


MG 


Madagascar 


TJ 


Tajikistan 


BE 


Belgium 


ON 


Guinea 


MK 


TItc former Yugoslav 


TM 


Turkmenistan 


BF 


Burkina Faso 


OR 


Greece 




Republic of Macedonia 


TR 


Turkey 


BG 


Bulgaria 


HU 


Hungary 


ML 


Mali 


TT 


Trinidad and Tobago 


BJ 


Benin 


tE 


Ireland 


MN 


Mongolia 


LA 


Ukraine 


BR 


Brazil 


IL 


Israel 


MR 


Mauritania 


UG 


Uganda 


BY 


Belarus 


IS 


Iceland 


MW 


Malawi 


US 


United States of America 


CA 


Canada 


IT 


Italy 


MX 


Mexico 


UZ 


Uzbekistan 


CF 


Central African Republic 


JP 


Japan 


NE 


Niger 


VN 


Viet Nam 


CG 


Congo 


K£ 


Kenya 


NL 


Netherlands 


YU 


Yugoslavia 


CH 


Switzerland 


KG 


Kyrgyzstan 


NO 


Norway 




Zimbabwe 


CI 


Cfitc d'lvoirc 


KP 


Democratic People's 


NZ 


New Zealand 






CM 


Cameroon 




Republic of Korea 


PL 


Poland 






CN 


China 


KR 


Republic of Korea 


PT 


Portugal 






cu 


Cuba 


KZ 


Kazaksian 


RO 


Romania 






cz 


Czech Republic 


LC 


Saint Lucia 


RU 


Russian Federation 






DB 


Germany 


LI 


IJcchtcnstein 


SO 


Sudan 






DK 


Denmark 


LK 


Sri Lanka 


SE 


Sweden 






EE 


Estonia 


LR 


Liberia 


SG 


Singapore 







